<template>

  <el-container>
    <!--     左边的图片-->
    <el-aside width="200px">
      <img src="../assets/loginBox2.jpg">
      <p class="imgTitle">
        欢迎使用动力云客系统
      </p>
    </el-aside>

    <!--    右边的表单-->
    <el-main>
      <div class="loginTitle">欢迎登录</div>

      <el-form ref="loginRefFrom" :model="user" label-width="120px" :rules="loginRules">
        <el-form-item label="账号" prop="loginAct">
          <el-input v-model="user.loginAct"/>
        </el-form-item>

        <el-form-item label="密码" prop="loginPwd">
          <el-input type="password" v-model="user.loginPwd"/>
        </el-form-item>

        <el-form-item label="  ">
          <el-button type="primary" @click="login">登 录</el-button>
        </el-form-item>

        <el-form-item label="  ">
          <el-checkbox label="记住我" v-model="user.rememberMe"/>
        </el-form-item>
      </el-form>

    </el-main>

  </el-container>

</template>

<script>
import {doGet, doPost} from "../http/httpRequest.js";
import {getTokenName, messageTip, removeToken} from "../util/util.js";

export default {
  //组件的名字
  name: "LoginView",

  //定义页面使用到的变量
  data() {
    return {
      //对象变量定义。是{}
      user: {},
      //字符串变量定义。是‘’
      name: '',
      //数字变量定义。是0
      age: 0,
      //数组变量定义。是[]
      arr: [],
      //list集合对象（对象数组）。是[{}]
      userList: [{}],
      //定义登录表单的验证规则
      loginRules: {
        //定义账号的验证规则，规则可以有多个，所以是数组
        loginAct: [
          {required: true, message: '请输入登录账号', trigger: 'blur'},
        ],
        //定义密码的验证规则，规则可以有多个，所以是数组
        loginPwd: [
          {required: true, message: '请输入登录密码', trigger: 'blur'},
          {min: 6, max: 16, message: '密码长度在6到16个字符之间', trigger: 'blur'}
        ]
      }
    };
  },

  //页面渲染dom元素后会触发调用该函数（函数钩子）
  mounted() {
    this.freeLogin();
  },

  //页面上需要使用功能的js函数，都在methods属性中定义
  methods: {
    //登录函数
    login() {
      //提交前验证输入框的合法性
      this.$refs.loginRefFrom.validate(isValid => {
        //isValid是验证后的结果，如果是true表示验证通过，否则未通过
        if (isValid) {
          //验证通过，可以提交登录
          let formData = new FormData();
          formData.append("loginAct", this.user.loginAct);
          formData.append("loginPwd", this.user.loginPwd);
          formData.append("rememberMe", this.user.rememberMe);

          doPost("/api/login",formData).then((resp) => {
            console.log(resp);
            if (resp.data.code == 200) {
              //登录成功，提示一下
              messageTip("登录成功","success")

              //删除一下历史localStorage和sessionStorage中存储的token
              removeToken();

              //前端存储jwt
              if (this.user.rememberMe === true){
                window.localStorage.setItem(getTokenName(),resp.data.data);
              }else {
                window.sessionStorage.setItem(getTokenName(),resp.data.data);
              }
              //跳转到系统主页面
              window.location.href="/dashboard"
            } else {
              //登录失败，提示错误信息
              messageTip("登陆失败","error")
            }
          })

        }
      })
    },

    //免登录（自动登录）
    freeLogin(){
      let token = window.localStorage.getItem(getTokenName());
      if (token){//表示token有值
        doGet("api/login/free",{}).then(resp =>{
          if (resp.data.code === 200){
            //token验证通过，那么可以免登录
            window.location.href = "/Dashboard";
          }
        })
      }
    }
  }
}

</script>

<style scoped>
.el-aside {
  background: #1a1a1a;
  //background: #dadcdd;
  width: 40%;
  text-align: center;
}

.el-main {
  height: calc(100vh);
}

img {
  //height: 413px;
  height: 382px;
  margin-top: 150px;
}

.imgTitle {
  color: #f9f9f9;
  font-size: 28px;
}

.el-form {
  width: 60%;
  margin: auto;
}

.loginTitle {
  text-align: center;
  margin-bottom: 25px;
  margin-top: 100px;
  font-weight: bold;
}

.el-button {
  width: 100%;
}
</style>